<!--
  * 房间
  *
  * @Author:    ZouYang
  * @Date:      2024-12-28 12:10:44
  * @Copyright  ZouYang
-->
<template>
  <a-modal
      :title="form.id ? '编辑' : '添加'"
      :width="600"
      :open="visibleFlag"
      @cancel="onClose"
      :maskClosable="false"
      :destroyOnClose="true"
  >
    <a-form ref="formRef" :model="form" :rules="rules" :label-col="{ span: 5 }" >
      <a-form-item label="楼层ID"  name="floorId">
        <a-input-number style="width: 100%" v-model:value="form.floorId" placeholder="楼层ID" />
      </a-form-item>
      <a-form-item label="房间号"  name="number">
        <a-input-number style="width: 100%" v-model:value="form.number" placeholder="房间号" />
      </a-form-item>
      <a-form-item label="房间名称"  name="name">
        <a-input style="width: 100%" v-model:value="form.name" placeholder="房间名称" />
      </a-form-item>
    </a-form>

    <template #footer>
      <a-space>
        <a-button @click="onClose">取消</a-button>
        <a-button type="primary" @click="onSubmit">保存</a-button>
      </a-space>
    </template>
  </a-modal>
</template>
<script setup>
import { reactive, ref, nextTick } from 'vue';
import _ from 'lodash';
import { message } from 'ant-design-vue';
import { SmartLoading } from '/@/components/framework/smart-loading';
import { roomApi } from '/@/api/business/school/room-api';
import { smartSentry } from '/@/lib/smart-sentry';

// ------------------------ 事件 ------------------------

const emits = defineEmits(['reloadList']);

// ------------------------ 显示与隐藏 ------------------------
// 是否显示
const visibleFlag = ref(false);

function show(rowData) {
  Object.assign(form, formDefault);
  if (rowData && !_.isEmpty(rowData)) {
    Object.assign(form, rowData);
  }
  // 使用字典时把下面这注释修改成自己的字典字段 有多个字典字段就复制多份同理修改 不然打开表单时不显示字典初始值
  // if (form.status && form.status.length > 0) {
  //   form.status = form.status.map((e) => e.valueCode);
  // }
  visibleFlag.value = true;
  nextTick(() => {
    formRef.value.clearValidate();
  });
}

function onClose() {
  Object.assign(form, formDefault);
  visibleFlag.value = false;
}

// ------------------------ 表单 ------------------------

// 组件ref
const formRef = ref();

const formDefault = {
  id: undefined,
  floorId: undefined, //楼层ID
  number: undefined, //房间号
  name: undefined, //房间名称
};

let form = reactive({ ...formDefault });

const rules = {
  floorId: [{ required: true, message: '楼层ID 必填' }],
  number: [{ required: true, message: '房间号 必填' }],
  name: [{ required: true, message: '房间名称 必填' }],
};

// 点击确定，验证表单
async function onSubmit() {
  try {
    await formRef.value.validateFields();
    save();
  } catch (err) {
    message.error('参数验证错误，请仔细填写表单数据!');
  }
}

// 新建、编辑API
async function save() {
  SmartLoading.show();
  try {
    if (form.id) {
      await roomApi.update(form);
    } else {
      await roomApi.add(form);
    }
    message.success('操作成功');
    emits('reloadList');
    onClose();
  } catch (err) {
    smartSentry.captureError(err);
  } finally {
    SmartLoading.hide();
  }
}

defineExpose({
  show,
});
</script>
